{% extends 'base/layout.html' %}
{% load form_helpers %}
{% load helpers %}

{% comment %}
Blocks:
  form: Content within the <form> element
  buttons: Form submission buttons

Context:
  object: Python instance of the object being edited
  form: The edit form
  return_url: The URL to which the user is redirected after submitting the form
{% endcomment %}

{% block title %}
  {% if object.pk %}Editing {{ object|meta:"verbose_name" }} {{ object }}{% else %}Add a new {{ object|meta:"verbose_name" }}{% endif %}
{% endblock title %}

{% block tabs %}
  <ul class="nav nav-tabs px-3">
    <li class="nav-item" role="presentation">
      <button class="nav-link active" id="edit-form-tab" data-bs-toggle="tab" data-bs-target="#edit-form" type="button" role="tab" aria-controls="edit-form" aria-selected="true">
        {% if object.pk %}Edit{% else %}Create{% endif %}
      </button>
    </li>
  </ul>
{% endblock tabs %}

{% block content-wrapper %}
  <div class="tab-content">
    <div class="tab-pane show active" id="edit-form" role="tabpanel" aria-labelledby="object-list-tab">

      {# Warn about missing prerequisite objects #}
      {% if prerequisite_model %}
        {% include 'inc/missing_prerequisites.html' %}
      {% endif %}

      {# Link to model documentation #}
      {% if object and settings.DOCS_ROOT %}
        <div class="float-end">
          <a href="{{ object|get_docs_url }}" target="_blank" class="btn btn-sm btn-outline-secondary" title="View model documentation">
            <i class="mdi mdi-help-circle"></i> Help
          </a>
        </div>
      {% endif %}

      <form action="" method="post" enctype="multipart/form-data" class="form-object-edit mt-5">
        {% csrf_token %}

        {% block form %}
          {% if form.fieldsets %}

            {# Render hidden fields #}
            {% for field in form.hidden_fields %}
              {{ field }}
            {% endfor %}

            {# Render grouped fields according to Form #}
            {% for group, fields in form.fieldsets %}
              <div class="field-group mb-5">
                {% if group %}
                  <div class="row mb-2">
                    <h5 class="offset-sm-3">{{ group }}</h5>
                  </div>
                {% endif %}
                {% for name in fields %}
                  {% with field=form|getfield:name %}
                    {% if not field.field.widget.is_hidden %}
                      {% render_field field %}
                    {% endif %}
                  {% endwith %}
                {% endfor %}
              </div>
            {% endfor %}

            {% if form.custom_fields %}
              <div class="field-group mb-5">
                <div class="row mb-2">
                  <h5 class="offset-sm-3">Custom Fields</h5>
                </div>
                {% render_custom_fields form %}
              </div>
            {% endif %}

            {% if form.comments %}
              <div class="field-group mb-5">
                <h5 class="text-center">Comments</h5>
                {% render_field form.comments %}
              </div>
            {% endif %}

          {% else %}
            {# Render all fields in a single group #}
            <div class="field-group mb-5">
              {% render_form form %}
            </div>
          {% endif %}

        {% endblock form %}

        <div class="text-end my-3">
          {% block buttons %}
            {% if object.pk %}
              <button type="submit" name="_update" class="btn btn-primary">
                Save
              </button>
            {% else %}
              <button type="submit" name="_create" class="btn btn-primary">
                Create
              </button>
              <button type="submit" name="_addanother" class="btn btn-outline-primary">
                Create & Add Another
              </button>
            {% endif %}
            <a class="btn btn-outline-danger" href="{{ return_url }}">Cancel</a>
          {% endblock buttons %}
        </div>
      </form>
    </div>
  </div>

{% endblock content-wrapper %}
